// pages/category/index.js
import {request}  from '../../request/index.js'

Page({

    /**
     * 页面的初始数据
     */
    data: {
        leftList: [],
        rightList: [],
        activeIndex: 0,
        scrollTop: 0
    },
    // 存放接口数据
    categoriesList: [],

    /**
     * 生命周期函数--监听页面加载
     */
    onLoad: function (options) {
       this.getPageData()
    },
    getPageData() {
         /**
         * 1. 判断本地存储是否有数据， 无=》 请求接口
         * 2. 有 =》 数据未过期， 使用缓存数据
         * 3. 有 =》 数据过期， 请求接口
         */
        const Cates = wx.getStorageSync('cates');
        // 无数据 或 已过期
        if(!Cates || Date.now()-Cates.time > 10*60*1000) {
            this.getCategoriesList()
        }else {
            this.categoriesList = Cates.data;
            this.setList(Cates.data)
        }
    },
    getCategoriesList() {
        request({
            url: '/categories'
        }).then(res => {
            if(!res?.message) return
            const categoriesList = res.message;
            wx.setStorageSync('cates', {time: Date.now(), data: categoriesList})
            this.categoriesList = categoriesList;
            this.setList(categoriesList)           
        })
    },
    // 设置值
    setList(categoriesList) {
        const leftList = categoriesList.map(item => item.cat_name)
        const rightList = categoriesList[0].children
        this.setData({
            leftList,
            rightList
        })
    },
    // 左侧选择门类的tap事件
    handleChange(e) {
        const {index} = e.currentTarget.dataset;
        const rightList = this.categoriesList[index]['children']
        this.setData({
            activeIndex: index,
            rightList,
            scrollTop: 0
        })
    },

    /**
     * 生命周期函数--监听页面初次渲染完成
     */
    onReady: function () {

    },

    /**
     * 生命周期函数--监听页面显示
     */
    onShow: function () {

    },

    /**
     * 生命周期函数--监听页面隐藏
     */
    onHide: function () {

    },

    /**
     * 生命周期函数--监听页面卸载
     */
    onUnload: function () {

    },

    /**
     * 页面相关事件处理函数--监听用户下拉动作
     */
    onPullDownRefresh: function () {

    },

    /**
     * 页面上拉触底事件的处理函数
     */
    onReachBottom: function () {

    },

    /**
     * 用户点击右上角分享
     */
    onShareAppMessage: function () {

    }
})